<template>
    <div>
        <el-card class="main-card">
            <el-row :gutter="12" class="mb8">
                <el-col :span="1.5">
                    <el-button icon="el-icon-plus" plain size="mini" type="primary" @click="handleAdd">{{ $t('add')
                    }}</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button icon="el-icon-view" plain size="mini" type="info" @click="handleOpenThingsModel">{{
                        $t('product.product-things-model.142341-3') }}</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button icon="el-icon-refresh" plain size="mini" type="primary" @click="getList">{{ $t('refresh')
                        }}</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button icon="el-icon-refresh" plain size="mini" type="primary" @click="synchronizaToProduct">{{
                        $t('index.VarTemp.20250324-08') }}</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-link :underline="false" style="padding-top: 5px" type="danger">{{
                        $t('product.product-things-model.142341-4') }}</el-link>
                </el-col>
            </el-row>
        </el-card>
        <el-card class="main-card">
            <el-table class="base-table" :border="false" v-loading="loading" :data="modelList" size="mini">
                <el-table-column align="center" :label="$t('product.thimgs-mopdel-list.738493-1')" prop="templateName"
                    width="200" />
                <el-table-column align="center" :label="$t('product.product-app.045891-3')" prop="identifier" />
                <el-table-column align="center" :label="$t('product.product-select-template.318012-8')" prop=""
                    width="80">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_yes_no" :value="scope.row.isChart" />
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-select-template.318012-9')" prop=""
                    width="80">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_yes_no" :value="scope.row.isMonitor" />
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-select-template.318012-10')" prop=""
                    width="75">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_yes_no" :value="scope.row.isReadonly" />
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-select-template.318012-11')" prop=""
                    width="80">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_yes_no" :value="scope.row.isHistory" />
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-things-model.142341-16')" prop="type"
                    width="100">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_things_type" :value="scope.row.type" />
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-things-model.142341-17')" prop="datatype"
                    width="80">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.iot_data_type" :value="scope.row.datatype" />
                    </template>
                </el-table-column>
                <el-table-column align="left" class-name="specsColor" header-align="center"
                    :label="$t('product.product-things-model.142341-18')" min-width="150" prop="specs">
                    <template slot-scope="scope">
                        <div v-html="formatSpecsDisplay(scope.row.specs)"></div>
                    </template>
                </el-table-column>
                <el-table-column align="center" :label="$t('product.product-things-model.142341-19')" prop="formula" />
                <el-table-column align="center" :label="$t('product.product-things-model.142341-20')" prop="modelOrder"
                    width="80" />
                <el-table-column align="center" class-name="small-padding fixed-width"
                    :label="$t('product.product-things-model.142341-21')" width="130">
                    <template slot-scope="scope">
                        <el-button v-if="productInfo.status != 2" icon="el-icon-edit" size="small" type="primary" plain
                            style="padding: 5px" @click="handleUpdate(scope.row)">{{ $t('update') }}</el-button>
                        <el-button v-if="productInfo.status != 2" icon="el-icon-delete" size="small" type="danger" plain
                            style="padding: 5px" @click="handleDelete(scope.row)">{{
                                $t('product.product-things-model.142341-23') }}</el-button>
                    </template>
                </el-table-column>
            </el-table>
        </el-card>
        <!-- 添加或修改物模型对话框 -->
        <el-dialog :title="title" :visible.sync="open" append-to-body width="600px">
            <el-form ref="form" :model="form" :rules="rules" label-width="100px">
                <el-form-item :label="$t('product.product-things-model.142341-24')" prop="templateName">
                    <el-input v-model="form.templateName" :placeholder="$t('product.product-things-model.142341-25')"
                        style="width: 385px" />
                </el-form-item>
                <el-form-item :label="$t('product.product-things-model.142341-26')" prop="identifier">
                    <el-input v-model="form.identifier" :placeholder="$t('product.product-things-model.142341-27')"
                        style="width: 385px" />
                </el-form-item>
                <el-form-item :label="$t('product.product-things-model.142341-28')" prop="modelOrder">
                    <el-input v-model="form.modelOrder" :placeholder="$t('product.product-things-model.142341-29')"
                        style="width: 385px" type="number" />
                </el-form-item>
                <el-form-item :label="$t('product.product-things-model.142341-30')" prop="type">
                    <el-radio-group v-model="form.type" @change="typeChange(form.type)">
                        <el-radio-button label="1">{{ $t('product.product-things-model.142341-31') }}</el-radio-button>
                        <el-radio-button label="2">{{ $t('product.product-things-model.142341-32') }}</el-radio-button>
                        <el-radio-button label="3">{{ $t('product.product-things-model.142341-33') }}</el-radio-button>
                    </el-radio-group>
                </el-form-item>
                <el-form-item :label="$t('product.product-things-model.142341-34')" prop="property">
                    <el-checkbox v-show="form.type == 1" v-model="form.isChart" :false-label="0" :true-label="1"
                        :label="$t('product.product-things-model.142341-12')" name="isChart"
                        @change="isChartChange"></el-checkbox>
                    <el-checkbox v-show="form.type == 1" v-model="form.isMonitor" :false-label="0" :true-label="1"
                        :label="$t('product.product-things-model.142341-13')" name="isMonitor"
                        @change="isMonitorChange"></el-checkbox>
                    <el-checkbox v-model="form.isReadonly" :disabled="form.type == 3" :false-label="0" :true-label="1"
                        :label="$t('product.product-things-model.142341-35')" name="isReadonly"
                        @change="isReadonlyChange"></el-checkbox>
                    <el-checkbox v-model="form.isHistory" :false-label="0" :true-label="1"
                        :label="$t('product.product-select-template.318012-11')" name="isHistory"></el-checkbox>
                </el-form-item>

                <el-divider></el-divider>
                <el-form-item :label="$t('product.product-select-template.318012-12')" prop="datatype">
                    <el-select v-model="form.datatype" :placeholder="$t('product.product-things-model.142341-37')"
                        style="width: 175px" @change="dataTypeChange">
                        <el-option key="integer" :label="$t('product.product-things-model.142341-38')"
                            value="integer"></el-option>
                        <el-option key="decimal" :label="$t('product.product-things-model.142341-39')"
                            value="decimal"></el-option>
                        <el-option key="bool" :disabled="form.isChart == 1"
                            :label="$t('product.product-things-model.142341-40')" value="bool"></el-option>
                        <el-option key="enum" :disabled="form.isChart == 1"
                            :label="$t('product.product-things-model.142341-41')" value="enum"></el-option>
                        <el-option key="string" :disabled="form.isChart == 1"
                            :label="$t('product.product-things-model.142341-42')" value="string"></el-option>
                        <el-option key="array" :disabled="form.isChart == 1"
                            :label="$t('product.product-things-model.142341-43')" value="array"></el-option>
                        <!-- <el-option key="object" label="对象" value="object" :disabled="form.isChart==1"></el-option> -->
                    </el-select>
                </el-form-item>
                <div v-if="form.datatype == 'integer' || form.datatype == 'decimal'">
                    <el-form-item :label="$t('product.product-things-model.142341-45')">
                        <el-row>
                            <el-col :span="9">
                                <el-input v-model="form.specs.min"
                                    :placeholder="$t('product.product-things-model.142341-46')" type="number" />
                            </el-col>
                            <el-col :span="2" align="center">{{ $t('product.product-things-model.142341-47') }}</el-col>
                            <el-col :span="9">
                                <el-input v-model="form.specs.max"
                                    :placeholder="$t('product.product-things-model.142341-48')" type="number" />
                            </el-col>
                        </el-row>
                    </el-form-item>
                    <el-form-item :label="$t('product.product-things-model.142341-49')">
                        <el-input v-model="form.specs.unit" :placeholder="$t('product.product-things-model.142341-50')"
                            style="width: 385px" />
                    </el-form-item>
                </div>
                <div v-if="form.datatype == 'bool'">
                    <el-form-item :label="$t('product.product-things-model.142341-63')" prop="">
                        <el-row style="margin-bottom: 10px">
                            <el-col :span="9">
                                <el-input v-model="form.specs.falseText"
                                    :placeholder="$t('product.product-things-model.142341-64')" />
                            </el-col>
                            <el-col :offset="1" :span="10">{{ $t('product.product-things-model.142341-65') }}</el-col>
                        </el-row>
                        <el-row>
                            <el-col :span="9">
                                <el-input v-model="form.specs.trueText"
                                    :placeholder="$t('product.product-things-model.142341-66')" />
                            </el-col>
                            <el-col :offset="1" :span="10">{{ $t('product.product-things-model.142341-67') }}</el-col>
                        </el-row>
                    </el-form-item>
                </div>
                <div v-if="form.datatype == 'enum'">
                    <el-form-item :label="$t('product.product-things-model.142341-68')">
                        <el-select v-model="form.specs.showWay"
                            :placeholder="$t('product.product-things-model.142341-69')" style="width: 175px">
                            <el-option key="select" :label="$t('product.product-things-model.142341-70')"
                                value="select"></el-option>
                            <el-option key="button" :label="$t('product.product-things-model.142341-71')"
                                value="button"></el-option>
                        </el-select>
                    </el-form-item>
                    <el-form-item :label="$t('product.product-things-model.142341-72')" prop="">
                        <el-row v-for="(item, index) in form.specs.enumList" :key="'enum' + index"
                            style="margin-bottom: 10px">
                            <el-col :span="9">
                                <el-input v-model="item.value"
                                    :placeholder="$t('product.product-things-model.142341-73')" />
                            </el-col>
                            <el-col :offset="1" :span="11">
                                <el-input v-model="item.text"
                                    :placeholder="$t('product.product-things-model.142341-74')" />
                            </el-col>
                            <el-col v-if="index != 0" :offset="1" :span="2"><a style="color: #f56c6c"
                                    @click="removeEnumItem(index)">{{ $t('del') }}</a></el-col>
                        </el-row>
                        <div>
                            +
                            <a style="color: #409eff" @click="addEnumItem()">{{
                                $t('product.product-things-model.142341-75')
                                }}</a>
                        </div>
                    </el-form-item>
                </div>
                <div v-if="form.datatype == 'string'">
                    <el-form-item :label="$t('product.product-things-model.142341-76')" prop="">
                        <el-row>
                            <el-col :span="9">
                                <el-input v-model="form.specs.maxLength"
                                    :placeholder="$t('product.product-things-model.142341-77')" type="number" />
                            </el-col>
                            <el-col :offset="1" :span="14">{{ $t('product.product-things-model.142341-78') }}</el-col>
                        </el-row>
                    </el-form-item>
                </div>
                <div v-if="form.datatype == 'array'">
                    <el-form-item :label="$t('product.product-things-model.142341-79')" prop="">
                        <el-row>
                            <el-col :span="9">
                                <el-input v-model="form.specs.arrayCount"
                                    :placeholder="$t('product.product-things-model.142341-80')" type="number" />
                            </el-col>
                        </el-row>
                    </el-form-item>
                    <el-form-item :label="$t('product.product-things-model.142341-81')" prop="">
                        <el-radio-group v-model="form.specs.arrayType">
                            <el-radio label="integer">{{ $t('product.product-things-model.142341-38') }}</el-radio>
                            <el-radio label="decimal">{{ $t('product.product-things-model.142341-39') }}</el-radio>
                            <el-radio label="string">{{ $t('product.product-things-model.142341-42') }}</el-radio>
                            <!-- <el-radio label="object">对象</el-radio> -->
                        </el-radio-group>
                    </el-form-item>
                    <el-form-item v-if="form.specs.arrayType == 'object'"
                        :label="$t('product.product-things-model.142341-82')">
                        <div style="background-color: #f8f8f8; border-radius: 5px">
                            <el-row v-for="(item, index) in form.specs.params" :key="index" style="padding: 0 10px 5px">
                                <div v-if="index == 0" style="margin-top: 5px"></div>
                                <el-col :span="18">
                                    <el-input v-model="item.name"
                                        :placeholder="$t('product.product-things-model.142341-83')" readonly size="mini"
                                        style="margin-top: 3px">
                                        <template slot="prepend">
                                            <el-tag effect="dark" size="mini"
                                                style="margin-left: -21px; height: 26px; line-height: 26px">
                                                {{ item.order }}
                                            </el-tag>
                                            {{ form.identifier + '_' + item.id }}
                                        </template>
                                        <el-button slot="append" size="small" @click="editParameter(item, index)">{{
                                            $t('product.product-things-model.142341-84') }}</el-button>
                                    </el-input>
                                </el-col>
                                <el-col :offset="2" :span="2">
                                    <el-button icon="el-icon-delete" plain size="small" style="padding: 5px"
                                        type="danger" @click="removeParameter(index)">{{
                                            $t('product.product-things-model.142341-86')
                                        }}</el-button>
                                </el-col>
                            </el-row>
                        </div>
                        <div>
                            +
                            <a style="color: #409eff" @click="addParameter()">{{
                                $t('product.product-things-model.142341-85')
                                }}</a>
                        </div>
                    </el-form-item>
                </div>
                <div v-if="form.datatype == 'object'">
                    <el-form-item :label="$t('product.product-things-model.142341-82')" prop="">
                        <div style="background-color: #f8f8f8; border-radius: 5px">
                            <el-row v-for="(item, index) in form.specs.params" :key="index" style="padding: 0 10px 5px">
                                <div v-if="index == 0" style="margin-top: 5px"></div>
                                <el-col :span="18">
                                    <el-input v-model="item.name"
                                        :placeholder="$t('product.product-things-model.142341-88')" readonly size="mini"
                                        style="margin-top: 3px">
                                        <template slot="prepend">
                                            <el-tag effect="dark" size="mini"
                                                style="margin-left: -21px; height: 26px; line-height: 26px">
                                                {{ item.order }}
                                            </el-tag>
                                            {{ form.identifier + '_' + item.id }}
                                        </template>
                                        <el-button slot="append" size="small" @click="editParameter(item, index)">{{
                                            $t('product.product-things-model.142341-84') }}</el-button>
                                    </el-input>
                                </el-col>
                                <el-col :offset="2" :span="2">
                                    <el-button icon="el-icon-delete" plain size="small" style="padding: 5px"
                                        type="danger" @click="removeParameter(index)">{{
                                            $t('product.product-things-model.142341-86')
                                        }}</el-button>
                                </el-col>
                            </el-row>
                        </div>
                        <div>
                            +
                            <a style="color: #409eff" @click="addParameter()">添加参数</a>
                        </div>
                    </el-form-item>
                </div>

                <el-form-item :label="$t('product.product-things-model.142341-19')">
                    <template slot="label">
                        <span>{{ $t('product.product-things-model.142341-19') }}</span>
                        <el-tooltip effect="light" placement="top" style="cursor: pointer">
                            <div slot="content">
                                {{ $t('product.product-things-model.142341-53') }}
                                <br />
                                {{ $t('product.product-things-model.142341-54') }}
                                <br />
                                {{ $t('product.product-things-model.142341-55') }}
                                <br />
                                {{ $t('product.product-things-model.142341-56') }}
                                <br />
                                {{ $t('product.product-things-model.142341-57') }}
                                <br />
                                {{ $t('product.product-things-model.142341-58') }}
                                <br />
                                {{ $t('product.product-things-model.142341-59') }}
                                <br />
                                {{ $t('product.product-things-model.142341-60') }}
                                <br />
                            </div>
                            <i class="el-icon-question" />
                        </el-tooltip>
                    </template>
                    <el-input v-model="form.formula" :placeholder="$t('product.product-things-model.142341-19')" />
                </el-form-item>
            </el-form>

            <div slot="footer" class="dialog-footer">
                <el-button type="primary" @click="submitForm">{{ $t('confirm') }}</el-button>
                <el-button @click="cancel">{{ $t('cancel') }}</el-button>
            </div>
        </el-dialog>

        <!--物模型参数类型-->
        <things-parameter :data="paramData" @dataEvent="getParamData($event)" />

        <!-- 物模型JSON -->
        <el-dialog :title="title" :visible.sync="openThingsModel" append-to-body width="600px">
            <div style="border: 1px solid #ccc; margin-top: -15px; height: 600px; overflow: scroll">
                <json-viewer :expand-depth="10" :value="thingsModel" copyable>
                    <template v-slot:copy>{{ $t('product.product-things-model.142341-92') }}</template>
                </json-viewer>
            </div>
            <div slot="footer" class="dialog-footer">
                <el-button type="info" @click="handleCloseThingsModel">{{ $t('product.thimgs-mopdel-list.738493-8')
                }}</el-button>
            </div>
        </el-dialog>

        <!-- 采集点对应所有产品 -->
        <el-dialog :title="title" :visible.sync="openView" append-to-body width="550px">
            <div style="color: red">{{ $t('index.VarTemp.20250324-09') }}</div>
            <el-table :border="false" v-loading="loading" :data="productList" highlight-current-row size="mini"
                style="width: 100%; height: 500px" @selection-change="selectionChange">
                <el-table-column type="selection" width="55"></el-table-column>
                <el-table-column align="left" header-align="center" :label="$t('index.VarTemp.20250324-10')"
                    min-width="60" prop="productId"></el-table-column>
                <el-table-column align="left" header-align="center" :label="$t('product.index.091251-0')"
                    min-width="120" prop="productName"></el-table-column>
                <el-table-column align="left" header-align="center" :label="$t('product.product-edit.473153-14')"
                    min-width="60" prop="transport"></el-table-column>
                <el-table-column align="left" header-align="center" :label="$t('index.VarTemp.20250324-11')"
                    min-width="80" prop="protocolCode"></el-table-column>
            </el-table>
            <div slot="footer" class="dialog-footer">
                <el-button @click="cancel">{{ $t('cancel') }}</el-button>
                <el-button type="primary" @click="submitSyncToProduct">{{ $t('index.VarTemp.20250324-12') }}</el-button>
            </div>
        </el-dialog>
    </div>
</template>

<style>
.specsColor {
    background-color: #fcfcfc;
}
</style>

<script>
import productSelectTemplate from '../product/product-select-template';
import JsonViewer from 'vue-json-viewer';
import 'vue-json-viewer/style.css';
import thingsParameter from '../template/parameter';
import { listTemplate, getTemplate, addTemplate, delTemplate, updateTemplate } from '@/api/iot/template';
import { selectByTempleId } from '@/api/iot/product';
import { synchron } from '@/api/iot/model';

export default {
    name: 'gateway-things-model',
    dicts: ['iot_things_type', 'iot_data_type', 'iot_yes_no'],
    components: {
        productSelectTemplate,
        thingsParameter,
        JsonViewer,
    },
    props: {
        product: {
            type: Object,
            default: null,
        },
    },

    created() {
        this.queryParams.tempSlaveId = this.$route.query && this.$route.query.templateId;
        this.getList();
    },

    data() {
        return {
            selectOpen: false,
            openView: false,
            // 物模型
            thingsModel: {},
            // 父组件接收的产品信息
            productInfo: {},
            // 子组件选中的id数组
            templateIds: [],
            // 遮罩层
            loading: false,
            // 选中数组
            ids: [],
            // 非单个禁用
            single: true,
            // 非多个禁用
            multiple: true,
            // 显示搜索条件
            showSearch: true,
            // 总条数
            total: 0,
            // 产品物模型表格数据
            modelList: [],
            productList: [],
            // 弹出层标题
            title: '',
            // 是否显示弹出层
            open: false,
            openThingsModel: false,
            // 查询参数
            queryParams: {
                productId: 0,
                pageNum: 1,
                pageSize: 100,
                tempSlaveId: 0,
            },
            // 表单参数
            form: {},
            // 对象类型参数
            paramData: {
                index: -1,
                parameter: {},
            },
            //是否是modbus
            isModbus: false,
            slaveList: [],
            slave: {},
            // 表单校验
            rules: {
                modelName: [
                    {
                        required: true,
                        message: '物模型名称不能为空',
                        trigger: 'blur',
                    },
                ],
                identifier: [
                    {
                        required: true,
                        message: '标识符，产品下唯一不能为空',
                        trigger: 'blur',
                    },
                ],
                modelOrder: [
                    {
                        required: true,
                        message: '模型排序不能为空',
                        trigger: 'blur',
                    },
                ],
                type: [
                    {
                        required: true,
                        message: '模型类别不能为空',
                        trigger: 'change',
                    },
                ],
                datatype: [
                    {
                        required: true,
                        message: '数据类型不能为空',
                        trigger: 'change',
                    },
                ],
            },
        };
    },

    methods: {
        /** 查询产品物模型列表 */
        getList() {
            this.loading = true;
            listTemplate(this.queryParams).then((response) => {
                this.modelList = response.rows;
                this.total = response.total;
                this.loading = false;
            });
        },

        // 取消按钮
        cancel() {
            this.open = false;
            this.openView = false;
            this.reset();
        },
        // 表单重置
        reset() {
            this.form = {
                templateId: null,
                userId: null,
                userName: null,
                tenantId: null,
                tenantName: null,
                identifier: null,
                modelOrder: 0,
                type: 1,
                datatype: 'integer',
                isSys: null,
                isChart: 1,
                isHistory: 1,
                isSharePerm: 1,
                isMonitor: 1,
                isReadonly: 1,
                delFlag: null,
                createBy: null,
                createTime: null,
                updateBy: null,
                updateTime: null,
                remark: null,
                specs: {
                    enumList: [
                        {
                            value: '',
                            text: '',
                        },
                    ],
                    arrayType: 'integer',
                    arrayCount: 5,
                    showWay: 'select', // 显示方式select=下拉选择框，button=按钮
                    params: [],
                },
            };
            this.resetForm('form');
        },
        /** 搜索按钮操作 */
        handleQuery() {
            this.queryParams.pageNum = 1;
            this.getList();
        },
        /** 重置按钮操作 */
        resetQuery() {
            this.resetForm('queryForm');
            this.handleQuery();
        },
        /** 新增按钮操作 */
        handleAdd() {
            this.reset();
            this.open = true;
            this.title = '添加物模型';
        },
        /** 修改按钮操作 */
        handleUpdate(row) {
            this.reset();
            const id = row.templateId || this.ids;
            getTemplate(id).then((response) => {
                let tempForm = response.data;
                this.open = true;
                this.title = '修改物模型';
                // Json转对象
                tempForm.specs = JSON.parse(tempForm.specs);
                if (!tempForm.specs.enumList) {
                    tempForm.specs.showWay = 'select';
                    tempForm.specs.enumList = [
                        {
                            value: '',
                            text: '',
                        },
                    ];
                }
                if (!tempForm.specs.arrayType) {
                    tempForm.specs.arrayType = 'integer';
                }
                if (!tempForm.specs.arrayCount) {
                    tempForm.specs.arrayCount = 5;
                }
                if (!tempForm.specs.params) {
                    tempForm.specs.params = [];
                }
                // 对象和数组中参数删除前缀
                if ((tempForm.specs.type == 'array' && tempForm.specs.arrayType == 'object') || tempForm.specs.type == 'object') {
                    for (let i = 0; i < tempForm.specs.params.length; i++) {
                        tempForm.specs.params[i].id = String(tempForm.specs.params[i].id).substring(String(tempForm.identifier).length + 1);
                    }
                }
                this.form = tempForm;
            });
        },
        /**查看物模型 */
        handleOpenThingsModel() {
            this.title = '物模型';
            // 生成物模型
            this.thingsModel = {
                properties: [],
                functions: [],
                events: [],
            };
            for (var i = 0; i < this.modelList.length; i++) {
                let thingsItem = {};
                thingsItem.id = this.modelList[i].identifier;
                thingsItem.name = this.modelList[i].modelName;
                if (this.modelList[i].type == 1) {
                    //属性
                    thingsItem.isChart = this.modelList[i].isChart;
                    thingsItem.isMonitor = this.modelList[i].isMonitor;
                    thingsItem.isHistory = this.modelList[i].isHistory;
                    thingsItem.isSharePerm = this.modelList[i].isSharePerm;
                    thingsItem.isReadonly = this.modelList[i].isReadonly;
                    thingsItem.datatype = JSON.parse(this.modelList[i].specs);
                    this.thingsModel.properties.push(thingsItem);
                } else if (this.modelList[i].type == 2) {
                    // 功能
                    thingsItem.isHistory = this.modelList[i].isHistory;
                    thingsItem.isSharePerm = this.modelList[i].isSharePerm;
                    thingsItem.isReadonly = this.modelList[i].isReadonly;
                    thingsItem.datatype = JSON.parse(this.modelList[i].specs);
                    this.thingsModel.functions.push(thingsItem);
                } else if (this.modelList[i].type == 3) {
                    // 事件
                    thingsItem.isHistory = this.modelList[i].isHistory;
                    thingsItem.isSharePerm = this.modelList[i].isSharePerm;
                    thingsItem.isReadonly = this.modelList[i].isReadonly;
                    thingsItem.datatype = JSON.parse(this.modelList[i].specs);
                    this.thingsModel.events.push(thingsItem);
                }
            }

            this.openThingsModel = true;
        },
        /**关闭物模型 */
        handleCloseThingsModel() {
            this.openThingsModel = false;
        },

        // 获取子组件的值
        getChildData(data) {
            this.templateIds = data;
        },

        /** 提交按钮 */
        submitForm() {
            this.$refs['form'].validate((valid) => {
                if (valid) {
                    // 验证对象或对象数组中的参数不能为空
                    if (this.form.datatype == 'object' || (this.form.datatype == 'array' && this.form.specs.arrayType == 'object')) {
                        if (!this.form.specs.params || this.form.specs.params == 0) {
                            this.$modal.msgError('对象的参数不能为空');
                            return;
                        }
                    }
                    // 验证对象参数标识符不能相同
                    if (this.form.specs.params && this.form.specs.params.length > 0) {
                        let arr = this.form.specs.params.map((item) => item.id).sort();
                        for (let i = 0; i < arr.length; i++) {
                            if (arr[i] == arr[i + 1]) {
                                this.$modal.msgError('参数标识 ' + arr[i] + ' 重复');
                                return;
                            }
                        }
                    }
                    //验证模型特性为图表展示时，数据类型是否为整数或者小数
                    if (this.form.isChart == 1 && this.form.datatype != 'integer' && this.form.isChart == 1 && this.form.datatype != 'decimal') {
                        this.$modal.msgError('请重新选择数据类型！');
                    } else if (this.form.templateId != null) {
                        // 格式化specs
                        let tempForm = JSON.parse(JSON.stringify(this.form));
                        tempForm.specs = this.formatThingsSpecs();
                        if (this.form.type == 2) {
                            tempForm.isMonitor = 0;
                            tempForm.isChart = 0;
                        } else if (this.form.type == 3) {
                            tempForm.isMonitor = 0;
                            tempForm.isChart = 0;
                        }
                        updateTemplate(tempForm).then((response) => {
                            this.$modal.msgSuccess('修改成功');
                            this.open = false;
                            this.getList();
                        });
                    } else {
                        // 格式化specs
                        let tempForm = JSON.parse(JSON.stringify(this.form));
                        tempForm.specs = this.formatThingsSpecs();
                        if (this.form.type == 2) {
                            tempForm.isMonitor = 0;
                        } else if (this.form.type == 3) {
                            tempForm.isMonitor = 0;
                            tempForm.isChart = 0;
                        }
                        tempForm.tempSlaveId = this.queryParams.tempSlaveId;
                        addTemplate(tempForm).then((response) => {
                            this.$modal.msgSuccess('新增成功');
                            this.open = false;
                            this.getList();
                        });
                    }
                }
            });
        },
        /** 删除按钮操作 */
        handleDelete(row) {
            const modelIds = row.templateId || this.ids;
            this.$modal
                .confirm('是否确认删除物模型编号为"' + modelIds + '"的数据项？')
                .then(function () {
                    return delTemplate(modelIds);
                })
                .then(() => {
                    this.getList();
                    this.$modal.msgSuccess('删除成功');
                })
                .catch(() => { });
        },

        /*选中同步到的产品*/
        selectionChange(selection) {
            this.productIds = selection.map((item) => item.productId);
        },

        //同步采集点模板到指定产品
        synchronizaToProduct() {
            const params = { templateId: this.queryParams.tempSlaveId };
            selectByTempleId(params).then((res) => {
                this.productList = res.data;
                this.openView = true;
                this.title = this.$t('index.VarTemp.20250324-13');
            });
        },
        /*同步模板到产品确认*/
        submitSyncToProduct() {
            const data = { productIds: this.productIds, templateId: this.queryParams.tempSlaveId };
            synchron(data).then((res) => {
                if (res.code == 200) {
                    this.$modal.msgSuccess(this.$t('index.VarTemp.20250324-14'));
                } else {
                    this.$modal.msgError(res.msg);
                }
                this.openView = false;
                this.reset();
            });
        },

        /** 导出按钮操作 */
        handleExport() {
            this.download(
                'iot/model/export',
                {
                    ...this.queryParams,
                },
                `model_${new Date().getTime()}.xlsx`
            );
        },
        // 类型改变
        typeChange(type) {
            if (type == 1) {
                this.form.isChart = 1;
                this.form.isHistory = 1;
                this.form.isSharePerm = 1;
                this.form.isMonitor = 1;
                this.form.isReadonly = 1;
                this.form.datatype = 'integer';
            } else if (type == 2) {
                this.form.isChart = 0;
                this.form.isHistory = 1;
                this.form.isSharePerm = 1;
                this.form.isMonitor = 0;
                this.form.isReadonly = 0;
            } else if (type == 3) {
                this.form.isChart = 0;
                this.form.isHistory = 1;
                this.form.isSharePerm = 0;
                this.form.isMonitor = 0;
                this.form.isReadonly = 1;
            }
        },
        // 是否图表展示改变
        isChartChange() {
            if (this.form.isChart == 1) {
                this.form.isReadonly = 1;
            } else {
                this.form.isMonitor = 0;
            }
        },
        // 是否实时监测改变
        isMonitorChange() {
            if (this.form.isMonitor == 1) {
                this.form.isReadonly = 1;
                this.form.isChart = 1;
            }
        },
        // 是否只读数据改变
        isReadonlyChange() {
            if (this.form.isReadonly == 0) {
                this.form.isMonitor = 0;
                this.form.isChart = 0;
            }
        },
        // 格式化物模型
        formatThingsSpecs() {
            var data = {};
            data.type = this.form.datatype;
            if (this.form.datatype == 'integer' || this.form.datatype == 'decimal') {
                data.min = Number(this.form.specs.min ? this.form.specs.min : 0);
                data.max = Number(this.form.specs.max ? this.form.specs.max : 100);
                data.unit = this.form.specs.unit ? this.form.specs.unit : '';
                data.step = Number(this.form.specs.step ? this.form.specs.step : 1);
            } else if (this.form.datatype == 'string') {
                data.maxLength = Number(this.form.specs.maxLength ? this.form.specs.maxLength : 1024);
            } else if (this.form.datatype == 'bool') {
                data.falseText = this.form.specs.falseText ? this.form.specs.falseText : '关闭';
                data.trueText = this.form.specs.trueText ? this.form.specs.trueText : '打开';
            } else if (this.form.datatype == 'enum') {
                data.showWay = this.form.specs.showWay;
                if (this.form.specs.enumList && this.form.specs.enumList[0].text != '') {
                    data.enumList = this.form.specs.enumList;
                } else {
                    data.showWay = 'select';
                    data.enumList = [
                        {
                            value: '0',
                            text: '低',
                        },
                        {
                            value: '1',
                            text: '高',
                        },
                    ];
                }
            } else if (this.form.datatype == 'array') {
                data.arrayType = this.form.specs.arrayType;
                data.arrayCount = this.form.specs.arrayCount ? this.form.specs.arrayCount : 5;
                if (data.arrayType == 'object') {
                    data.params = this.form.specs.params;
                    // 物模型名称作为参数的标识符前缀
                    for (let i = 0; i < data.params.length; i++) {
                        data.params[i].id = this.form.identifier + '_' + data.params[i].id;
                    }
                }
            } else if (this.form.datatype == 'object') {
                data.params = this.form.specs.params;
                // 物模型名称作为参数的标识符前缀
                for (let i = 0; i < data.params.length; i++) {
                    data.params[i].id = this.form.identifier + '_' + data.params[i].id;
                }
            }
            return JSON.stringify(data);
        },
        /** 数据类型改变 */
        dataTypeChange(val) { },
        /** 添加枚举项 */
        addEnumItem() {
            this.form.specs.enumList.push({
                value: '',
                text: '',
            });
        },
        /** 删除枚举项 */
        removeEnumItem(index) {
            this.form.specs.enumList.splice(index, 1);
        },
        /** 格式化显示数据定义 */
        formatSpecsDisplay(json) {
            let specs = JSON.parse(json);
            if (specs.type === 'integer' || specs.type === 'decimal' || specs.type === 'INT16' || specs.type === 'INT') {
                return (
                    '<span style=\'width:50%;display:inline-block;\'>最大值：<span style="color:#F56C6C">' +
                    specs.max +
                    '</span></span>最小值：<span style="color:#F56C6C">' +
                    specs.min +
                    '</span><br /><span style=\'width:50%;display:inline-block;\'>步长：<span style="color:#F56C6C">' +
                    specs.step +
                    '</span></span>单位：<span style="color:#F56C6C">' +
                    specs.unit
                );
            } else if (specs.type === 'string') {
                return '最大长度：<span style="color:#F56C6C">' + specs.maxLength + '</span>';
            } else if (specs.type === 'array') {
                return '<span style=\'width:50%;display:inline-block;\'>数组类型：<span style="color:#F56C6C">' + specs.arrayType + '</span></span>元素个数：<span style="color:#F56C6C">' + specs.arrayCount;
            } else if (specs.type === 'enum') {
                let items = '';
                for (let i = 0; i < specs.enumList.length; i++) {
                    items = items + "<span style='width:50%;display:inline-block;'>" + specs.enumList[i].value + "：<span style='color:#F56C6C'>" + specs.enumList[i].text + '</span></span>';
                    if (i > 0 && i % 2 != 0) {
                        items = items + '<br />';
                    }
                }
                return items;
            } else if (specs.type === 'bool') {
                return '<span style=\'width:50%;display:inline-block;\'>0：<span style="color:#F56C6C">' + specs.falseText + '</span></span>1：<span style="color:#F56C6C">' + specs.trueText;
            } else if (specs.type === 'object') {
                let items = '';
                for (let i = 0; i < specs.params.length; i++) {
                    items = items + "<span style='width:50%;display:inline-block;'>" + specs.params[i].name + "：<span style='color:#F56C6C'>" + specs.params[i].datatype.type + '</span></span>';
                    if (i > 0 && i % 2 != 0) {
                        items = items + '<br />';
                    }
                }
                return items;
            }
        },
        /** 添加参数 */
        addParameter() {
            this.paramData = {
                index: -1,
                parameter: {},
            };
        },
        /** 编辑参数*/
        editParameter(data, index) {
            this.paramData = null;
            this.paramData = {
                index: index,
                parameter: data,
            };
        },
        /** 删除动作 */
        removeParameter(index) {
            this.form.specs.params.splice(index, 1);
        },
        /**获取设置的参数对象*/
        getParamData(data) {
            if (data.index == -1) {
                this.form.specs.params.push(data.parameter);
            } else {
                this.form.specs.params[data.index] = data.parameter;
                // 解决数组在界面中不更新问题
                this.$set(this.form.specs.params, data.index, this.form.specs.params[data.index]);
            }
        },
    },
};
</script>
